home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Gigarom 1
/
Gigarom Macintosh Archives (Quantum Leap)(CDRM1080320)(1993).iso
/
FILES
/
DEV
/
I-Z
/
Xlisp_Source.cpt
/
xlsym.c
< prev
next >
Wrap
Text File
|
1980-01-01
|
4KB
|
172 lines
/* xlsym - symbol handling routines */
#include "xlisp.h"
/* external variables */
extern NODE *oblist,*keylist;
extern NODE *s_unbound;
extern NODE *xlstack;
/* forward declarations */
FORWARD NODE *symenter();
FORWARD NODE *xlmakesym();
FORWARD NODE *findprop();
/* xlenter - enter a symbol into the oblist or keylist */
NODE *xlenter(name,type)
char *name;
{
return (symenter(name,type,(*name == ':' ? keylist : oblist)));
}
/* symenter - enter a symbol into a package */
LOCAL NODE *symenter(name,type,listsym)
char *name; int type; NODE *listsym;
{
NODE *oldstk,*lsym,*nsym,newsym;
int cmp;
/* check for nil */
if (strcmp(name,"nil") == 0)
return (NIL);
/* check for symbol already in table */
lsym = NIL;
nsym = listsym->n_symvalue;
while (nsym) {
if ((cmp = strcmp(name,xlsymname(car(nsym)))) <= 0)
break;
lsym = nsym;
nsym = cdr(nsym);
}
/* check to see if we found it */
if (nsym && cmp == 0)
return (car(nsym));
/* make a new symbol node and link it into the list */
oldstk = xlsave(&newsym,NULL);
newsym.n_ptr = newnode(LIST);
rplaca(newsym.n_ptr,xlmakesym(name,type));
rplacd(newsym.n_ptr,nsym);
if (lsym)
rplacd(lsym,newsym.n_ptr);
else
listsym->n_symvalue = newsym.n_ptr;
xlstack = oldstk;
/* return the new symbol */
return (car(newsym.n_ptr));
}
/* xlsenter - enter a symbol with a static print name */
NODE *xlsenter(name)
char *name;
{
return (xlenter(name,STATIC));
}
/* xlmakesym - make a new symbol node */
NODE *xlmakesym(name,type)
char *name;
{
NODE *oldstk,sym,*str;
/* create a new stack frame */
oldstk = xlsave(&sym,NULL);
/* make a new symbol node */
sym.n_ptr = newnode(SYM);
sym.n_ptr->n_symvalue = (*name == ':' ? sym.n_ptr : s_unbound);
sym.n_ptr->n_symplist = newnode(LIST);
rplaca(sym.n_ptr->n_symplist,str = newnode(STR));
str->n_str = (type == DYNAMIC ? strsave(name) : name);
str->n_strtype = type;
/* restore the previous stack frame */
xlstack = oldstk;
/* return the new symbol node */
return (sym.n_ptr);
}
/* xlsymname - return the print name of a symbol */
char *xlsymname(sym)
NODE *sym;
{
return (car(sym->n_symplist)->n_str);
}
/* xlgetprop - get the value of a property */
NODE *xlgetprop(sym,prp)
NODE *sym,*prp;
{
NODE *p;
return ((p = findprop(sym,prp)) ? car(p) : NIL);
}
/* xlputprop - put a property value onto the property list */
xlputprop(sym,val,prp)
NODE *sym,*val,*prp;
{
NODE *oldstk,p,*pair;
if ((pair = findprop(sym,prp)) == NIL) {
oldstk = xlsave(&p,NULL);
p.n_ptr = newnode(LIST);
rplaca(p.n_ptr,prp);
rplacd(p.n_ptr,pair = newnode(LIST));
rplaca(pair,val);
rplacd(pair,cdr(sym->n_symplist));
rplacd(sym->n_symplist,p.n_ptr);
xlstack = oldstk;
}
rplaca(pair,val);
}
/* xlremprop - remove a property from a property list */
xlremprop(sym,prp)
NODE *sym,*prp;
{
NODE *last,*p;
last = NIL;
for (p = cdr(sym->n_symplist); consp(p) && consp(cdr(p)); p = cdr(last)) {
if (car(p) == prp)
if (last)
rplacd(last,cdr(cdr(p)));
else
rplacd(sym->n_symplist,cdr(cdr(p)));
last = cdr(p);
}
}
/* findprop - find a property pair */
LOCAL NODE *findprop(sym,prp)
NODE *sym,*prp;
{
NODE *p;
for (p = cdr(sym->n_symplist); consp(p) && consp(cdr(p)); p = cdr(cdr(p)))
if (car(p) == prp)
return (cdr(p));
return (NIL);
}
/* xlsinit - symbol initialization routine */
xlsinit()
{
/* initialize the oblist */
oblist = xlmakesym("*oblist*",STATIC);
oblist->n_symvalue = newnode(LIST);
rplaca(oblist->n_symvalue,oblist);
/* initialize the keyword list */
keylist = xlsenter("*keylist*");
/* enter the unbound symbol indicator */
s_unbound = xlsenter("*unbound*");
s_unbound->n_symvalue = s_unbound;
}